Memory efficient 3-D wavelet transform for video coding without boundary effects

ABSTRACT

A video coding system and method utilizes a 3-D wavelet transform that is memory efficient and reduces boundary effect across frame boundaries. The transform employs a lifting-based scheme and buffers wavelet coefficients at intermediate lifting steps towards the end of one GOP (group of pictures) until intermediate coefficients from the beginning of the next GOP are available. The wavelet transform scheme does not physically break the video sequence into GOPs, but processes the sequence without intermission. In this manner, the system simulates an infinite wavelet transformation across frame boundaries and the boundary effect is significantly reduced or essentially eliminated. Moreover, the buffering is very small and the scheme can be used to implement other decomposition structures. The wavelet transform scheme provides superb video playback quality with little or no boundary effects.

TECHNICAL FIELD

[0001] This invention relates to systems and methods for video coding. More particularly, this invention relates to systems and methods that employ wavelet transforms for video coding.

BACKGROUND

[0002] Efficient and reliable delivery of video data is becoming increasingly important as the Internet continues to grow in popularity. Video is very appealing because it offers a much richer user experience than static images and text. It is more interesting, for example, to watch a video clip of a winning touchdown or a Presidential speech than it is to read about the event in stark print.

[0003] Unfortunately, video data is -significantly larger than other data types commonly delivered over the Internet. As an example, one second of uncompressed video data may consume one or more Megabytes of data. Delivering such large amounts of data over error-prone networks, such as the Internet and wireless networks, presents difficult challenges in terms of both efficiency and reliability.

[0004] To promote efficient delivery, video data is typically encoded prior to delivery to reduce the amount of data actually being transferred over the network. Image quality is lost as a result of the compression, but such loss is generally tolerated as necessary to achieve acceptable transfer speeds. In some cases, the loss of quality may not even be detectable to the viewer.

[0005] Video compression is well known. One common type of video compression is a motion-compensation-based video coding scheme, which is used in such coding standards as MPEG-1, MPEG-2, MPEG-4, H.261, and H.263. Such video compression schemes use predictive approaches that encode information to enable motion prediction from one video frame to the next.

[0006] An alternative to predictive-based video coding schemes is three dimensional (3-D) wavelet video coding. One advantage of 3-D wavelet coding over predictive video coding schemes is scalability (including rate, PSNR, spatial, and temporal), which facilitates video delivery over heterogeneous networks (e.g., the Internet) and future wireless video services. Existing encoders may use 3-D wavelet coding to seamlessly adapt to different channel conditions, such as bandwidth fluctuation and packet errors/losses, while existing decoders can adapt to different computational resources.

[0007] In a typical 3-D wavelet video coder, a two-dimensional (2-D) spatial transform and a one-dimensional (1-D) temporal transform are performed separately. Usually spatial decomposition is applied after temporal decomposition.

[0008]FIG. 1 illustrates a 3-D wavelet coding process on a video sequence 100 consisting of multiple 2-D matrices or frames of pixel data 102. The coding process typically segments the sequence into multiple groups of pictures (GOP), as represented by four-frame GOP 104. A first level temporal decomposition is applied to each GOP in the video sequence to produce sequence 110. In this example, a 2:1 compression ratio is used as indicted by shading every other frame. Subsequently, a second level temporal decomposition is applied to each GOP in the video sequence to produce sequence 120. In this example, a 4:1 compression ratio is used in the second level temporal decomposition, as indicated by every fourth frame being shaded.

[0009] A spatial decomposition is then performed on the sequence 100 to produce sequence 130. Spatial decomposition is applied with each frame independently. Here, every fourth frame is spatially decomposed.

[0010] One drawback of current 3-D wavelet coders is that frame quality or PSNR drops severely at the boundaries between each group of pictures (GOP), sometimes up to several decibels. This results in jittering artifacts in video playback, which can be very annoying to a viewer.

[0011]FIG. 2 illustrates the boundary effect in which the resulting image quality fluctuates at boundaries between consecutive GOPs. The lower graph 200 shows consecutive GOPs 1, 2, 3, 4, etc. Each GOP contains five frames. The upper graph 202 shows the visual quality fluctuation within one GOP, such as GOP. 2 Notice that the quality is significantly worse at the first and last frame of each; GOP, causing the jittering artifacts in video playback.

[0012] One explanation for this boundary disorder is that conventional wavelet coding schemes improve as the number of frames in each GOP increases. Many schemes assume an infinitely long GOP containing a sequence of infinitely many frames. Unfortunately, GOP length is limited in practice due to delay or memory constraints. Coders and decoders, for example, commonly employ small-size buffers that hold only a few frames at a time. Thus, conventional coding schemes exhibit the boundary effect consistent with the GOP length. If memory was infinitely large, a coder could potentially buffer the whole video sequence and process it as a whole in 3-D wavelet transform and bit-plane coding.

[0013] Accordingly, there is a need for a memory efficient 3-D wavelet transform for video coding that reduces or effectively eliminates the boundary effect.

SUMMARY

[0014] A video coding system and method utilizes a 3-D wavelet transform that is memory efficient and reduces the boundary effect. The wavelet transform employs a lifting scheme to decompose video frames into wavelet coefficients. The system buffers partially-processed wavelet coefficients at intermediate lifting steps for the last part of one GOP until intermediate coefficients from the beginning of the next GOP are available.

[0015] The wavelet transform scheme does not physically break the video sequence into GOPs, but processes the sequence without intermission. As a result, the system simulates an infinite wavelet transformation across GOP boundaries, as if the system were employing infinite memory. The boundary effect is therefore significantly reduced or essentially eliminated. Moreover, the buffering is very small and the scheme can be used to implement other decomposition structures.

[0016] A decoding system that employs an inverse 3-D wavelet transform is also disclosed. The wavelet transform scheme provides superb video playback quality with little or no boundary effects.

BRIEF DESCRIPTION OF THE DRAWINGS

[0017]FIG. 1 illustrates frames in a video sequence and a 3-D wavelet coding process on the video sequence 100.

[0018]FIG. 2 illustrates a boundary effect in which the image quality due to the coding process fluctuates at boundaries between consecutive groups of pictures (GOPs).

[0019]FIG. 3 is a block diagram of a video distribution system, including a video encoder at a content producer/provider and a video decoder at a client.

[0020]FIG. 4 illustrates a basic element of a lifting structure, which represents an elementary lifting operation employed during video encoding.

[0021]FIG. 5 illustrates a lifting structure formed from multiple basic lifting elements of FIG. 4.

[0022]FIG. 6 is a flow diagram of a video encoding/decoding process implemented by the video distribution system.

[0023]FIG. 7 illustrates two versions of a lifting structure during an initialization operation for a one-level decomposition.

[0024]FIG. 8 illustrates the lifting structure just after the initialization operation of FIG. 7.

[0025]FIG. 9 illustrates the lifting structure during one-level decomposition of an odd frame.

[0026]FIG. 10 illustrates the lifting structure during one-level decomposition of an even frame.

[0027]FIG. 11 illustrates two versions of the lifting structure during a flushing stage of the one-level decomposition.

[0028]FIG. 12 illustrates two versions of a lifting structure during an initialization operation for a one-level wavelet synthesis.

[0029]FIG. 13 illustrates the lifting structure one-level synthesis of an odd coefficient.

[0030]FIG. 14 illustrates the lifting structure one-level synthesis of an even coefficient.

[0031]FIG. 15 illustrates a two-level Mallat decomposition structure.

[0032]FIG. 16 is a graph that shows PSNR curves for transform schemes using uniform quantization and coding.

[0033]FIG. 17 is a graph that shows PSNR curves for transform schemes using 3-D SPIHT coding at 20 kbps.

DETAILED DESCRIPTION

[0034] This disclosure describes a video coding scheme that utilizes a 3-D wavelet transform that is memory efficient and significantly reduces boundary effect. The coding scheme is described in the context of delivering video data over a network, such as the Internet or a wireless network. However, the video coding scheme has general applicability to a wide variety of environments.

[0035] Exemplary System Architecture

[0036]FIG. 3 shows a video distribution system 300 in which a content producer/provider 302 produces and/or distributes video over a network 304 to a client 306. The network 304 is representative of many different types of networks, including cable, the Internet, a LAN (local area network), a WAN (wide area network), a SAN (storage area network), and wireless networks (e.g., satellite, cellular, RF, microwave, etc.).

[0037] The content producer/provider 302 may be implemented in many ways, 19 including as one or more server computers configured to store, process, and distribute video data. The content producer/provider 302 has a video storage 310 21 to store digital video files 312 and a distribution server 314 to encode the video data and distribute it over the network 304. The server 304 has one or more processors 320, an operating system 322 (e.g., Windows NT, Unix, etc.), and a video encoder 324. The video encoder 324 may be implemented in software, firmware, and/or hardware. The encoder is shown as a separate standalone module for discussion purposes, but may be constructed as part of the processor 320 or incorporated into operating system 322 or other applications,(not shown).

[0038] The video encoder 324 encodes the video data stored as files 312 using a 3-D wavelet transformer 326. The transformer 326 employs a 3-D wavelet transform scheme in combination with a lifting-based scheme to implement a memory-constrained wavelet analysis. The lifting-based scheme is implemented as a lifting structure 328 of elementary lifting operations, which are described below in more detail.

[0039] The 3-D wavelet transformer 326 uses a finite buffer 330 to continuously process sequential video frames, essentially creating an effect of having infinite memory, even though the buffer is rather small. The transformer 326 buffers, coefficients at intermediate lifting steps near the end of one GOP and continues processing until intermediate coefficients from the beginning of the next GOP are available. The wavelet transform scheme does not physically break the sequence into GOPs, but processes the video frame sequence without intermission. In this manner, the boundary effect is significantly reduced or essentially eliminated. Moreover, the buffering is very small and the scheme can be used to implement other decomposition structures.

[0040] The client 306 may be embodied in many different ways, including as a computer, a handheld device, a set-top box, a television, a game console, and so forth. The client 306 is equipped with a processor 340, a memory 342, and one or more media output devices 344. The memory 342 stores an operating system 350 (e.g., a Windows-brand operating system) that executes on the processor 340.

[0041] The operating system 350 implements a client-side video decoder 352 to decode the video stream. The decoder employs an inverse wavelet transformer 354 to decode the video stream. The inverse transformer 354 uses a lifting structure 356 similar to structure 328 at the encoder 324, but with different lifting coefficient and phase, to perform wavelet synthesis. The inverse transformation is aided by a finite buffer 358 that stores lifting coefficients produced during the synthesis.

[0042] Following decoding, the client stores the video in memory 342 and/or plays the video via the media output devices 344. The wavelet transform scheme provides superb video playback quality with little or no boundary effects.

[0043] Exemplary Lifting Structure

[0044] As noted above, the transformer 326 in encoder 324 utilizes a lifting-based scheme to implement a memory-constrained wavelet analysis. According to the lifting scheme, every FIR (finite impulse response) wavelet or filter bank can be decomposed into lifting steps and each lifting step can be further split into elementary operations.

[0045]FIG. 4 shows a basic element 400 of a lifting structure and represents an elementary lifting operation. The lifting element 400 has three input nodes 402, 18 404, and 406, and one output node 408. Each node denotes a frame of pixel data 19 or wavelet coefficients produced from processing the pixel data. The input frames are labeled as x₀, x₁, and x₂ and the output frame is labeled as y. The structure represents the following function:

y=x ₁ +w*(x ₀ +x ₂)

[0046] The “w” represents a weighting factor, which varies according to the filter type employed. As one example, the filter may be an x9-7 filter that implements nine lifting steps for low pass filtering and seven lifting steps for high pass filtering. However, other filters may be used.

[0047]FIG. 5 shows a lifting structure 500 formed by interconnecting multiple basic elements 400. The lifting structure 500 has input nodes 502(1)-502(10). Paths leading from the input nodes represent a lifting algorithm that is applied to the input frames to derive a set of high-pass wavelet coefficients at nodes 504(1)-504(5) and a set of low-pass wavelet coefficients at nodes 506(1)-5,06(5). The “a”, “b”, “c”, and “d” are weighting factors applied to basic elements in the lifting structure, in the manner described above with respect to FIG. 4.

[0048] General Video Encoding/Decoding Process

[0049]FIG. 6 shows a general video encoding/decoding process 600, which may be implemented by the video encoder 324 and video decoder 352 of system 300 (FIG. 3). The process 600 may be implemented in software as computer executable instructions that, when executed on one or more processors, perform the operations shown as blocks in FIG. 6.

[0050] At block 602, the video encoder 324 decomposes a sequence of video frames using a 3-D wavelet transformation and lifting structure 500. The decomposition operation 602 may be broken into three sub-operations, as represented by blocks 602(1)-602(3). At block 602(1), the wavelet transformer 326 initializes the finite buffer 330 with initial video frames in a video sequence. The transformer 326 then processes the input frames and subsequent frames continuously processes the initial and subsequent frames according to the lifting structure 500 (block 602(2)). Fully-processed coefficients are output from the buffer and partially-processed coefficients at intermediate lifting steps remain in the buffer until a next frame is input. Once a wavelet coefficient is output, buffer space is released and a new frame is pushed into the buffer, thereby allowing ongoing computations. When the last frame is pushed into the buffer, the last set of wavelet coefficients are computed and output (block 602(3)).

[0051] At block 604, the content provider 302 delivers the encoded video over network 304 to the client 306. The encoded video includes the wavelet coefficients from the decomposed video. At block 606, the client 306 receives the encoded video and passes the wavelet coefficients to the video decoder 352. The video decoder 352 then decodes the video using wavelet synthesis (block 608).

[0052] More particularly, the synthesis operation may be divided into three sub-operations similar to the decomposition operations. At block 608(1), the inverse transformer 354 initializes a finite buffer 358 with initial samples. The inverse transformer 354 then processes the frames using the lifting structure 356 (block 608(2)), until the last frame is pushed into the buffer and processed through the structure (block 608(3)).

[0053] The transformation operation 602 and the synthesis operation 608 are described in more detail below.

[0054] 3-D Wavelet Transformation (Block 602)

[0055] The video encoder 324 uses the lifting structure 500 in combination with a limited-size buffer 330 to simulate input and processing of an infinitely long sequence of video frames. The video encoder 324 thus creates the effect of having infinite memory, even though the memory is in fact finite. At GOP boundaries, e encoder buffers partially-processed coefficients at intermediate lifting nodes in structure 500 near the end of one GOP until intermediate coefficients from the beginning of the next GOP are available.

[0056] Wavelet decomposition may be performed at one or more levels. To demonstrate the basic transformation, one-level wavelet decomposition is described first, followed by multi-level wavelet decomposition. In this example, he focus is mainly on a 1-D temporal transform for artifact elimination, while spatial transforms are computed using traditional approaches with symmetric extensions over the boundaries. In particular, for purposes of continuing discussion and without losing generality, a wavelet transform using a Daubechies 9-7 biorthogonal filter is described. In the case of a video sequence, the one dimensional input signal is a frame in the video sequence.

[0057] For one-level temporal decomposition, the video encoder implements the lifting scheme with minimal buffer size and minimal delay by performing the lifting steps in elementary operations. Considering the lifting structure 500 of FIG. 5, each output frame is at most related to the next four frames. Thus, in one implementation, a small buffer of a size sufficient to hold just five frames of data may be employed. Let B0, B1, B2, B3, and B4 represent the contents of five frame-size areas in buffer 330, and f[n] denote the one-dimensional sequence of input samples, where nε[0, N-1], N is an even number.

[0058] Video frames are pushed into the buffer 330 one by one and a wavelet transform frame containing wavelet coefficients is output immediately when it is available. As noted in FIG. 6, the decomposition consists of three phases: (1) initialization, (2) pipeline processing, and (3) flushing. These three phases are described separately below.

[0059] Initialization (Block 602(1))

[0060] During initialization, the first five frames in a video sequence are pushed into the buffer areas B0-B4 of buffer 330. FIG. 7 shows two views of a lifting structure during the initialization operation for a one-level decomposition. The first view of the lifting structure, represented by reference number 700(1), shows the structure when the initial five frames F0-F4 are loaded into buffer areas B0-B4 at input nodes 702 of the lifting structure.

[0061] Throughout this discussion, nodes drawn as solid black dots indicate that data is present and paths drawn in solid black lines indicate that the operations have been performed. Nodes drawn as empty circles indicate that the nodes do not yet contain data and paths drawn as hollow lines indicate that the operations have not yet been performed. Here,.data is present at input nodes 702 and not at output nodes 704 and 706. None of the operations has been performed.

[0062] Weighting variables a, b, c and d are applied to the various paths. Notice that the weights “2b” and “2d” applied to the topmost basic lifting elements are a symmetric extension to account for the left boundary of the first frame. That is, these weights account for paths that should be leading into the topmost intermediate node 704 and topmost output node 706 from above, as if there were values existing before receipt of the first frame B0.

[0063] The second view of the lifting structure, represented by reference number 700(2), shows completion of the initialization phase after the operations have been performed. The intermediate and output nodes 704 and 706 now hold coefficients that result from processing, as represented by their solid black appearance. The paths are also filled to demonstrate that the operations have been performed.

[0064] At completion of the initialization operation, the contents of buffer B0 form a wavelet frame that is ready for output. The contents of buffer areas B1-B3 are at various stages of computation and the content of buffer area B4 contains the last initialization frame F4.

[0065] Pipeline Processing (Block 602(2))

[0066] After initialization, wavelet transform computing is processed in a pipeline. That is, the first wavelet frame is output, freeing the buffer area previously used to hold that wavelet frame (e.g., buffer area B0). The buffer contents are updated to free up a new buffer area to hold a next frame. The buffers are updated by shifting their contents to a next higher buffer area in the structure, as follows:

B0 is output,

B0←B1,

B1←B2,

B2←B3,

B3←B4,

B4←a new frame.

[0067] Notice that a new wavelet frame now resides in buffer area B0 and a new frame is pushed into the buffer area B4.

[0068]FIG. 8 shows a version of the lifting structure 800 at a point when the new wavelet frame is output and the buffers are updated, but prior to receiving the next input frame F5 (as represented by the empty nodes and paths). Once the new frame is input to the buffer area B4, the wavelet processing continues according to the lifting structure.

[0069] Due to the architecture of the lifting structure 500 (FIG. 5), alternating odd and even frames are computed differently through the various computational paths dictated by the lifting elements. If the input frame is odd-numbered, the following elementary operations are performed:

B4←B4+a*B3,

B3←B3+b*B2,

B2←B2+c*B1,

B1←B1+d*B0,

Output B0.

[0070]FIG. 9 shows a version of the lifting structure 900 upon input of an odd frame. F5 into buffer area B4 (node 902). The above operations are performed, resulting in an output of a wavelet frame from buffer B0 (node 904).

[0071] Conversely, if the input frame is even-numbered, the following elementary operations are performed:

B3←B3+a*B4,

B2←B2+b*B3,

B1←B1+c*B2,

B0←B0+d*B1,

Output B0.

[0072]FIG. 10 shows a version of the lifting structure 1000 upon input of subsequent even frame F6 into buffer area B4 (node 1002). The above operations are performed, resulting in an output of a wavelet frame from buffer B0 (node 1004).

[0073] Flushing Stage (Block 602(3))

[0074] When the last frame is pushed into the buffer, the last five wavelet frames are computed and output. FIG. 11 shows two views of a lifting structure during the flushing stage of one-level decomposition. The first view of the lifting structure, represented by reference number 1100(1), shows the structure when the last five frames FN-4 to FN are loaded into buffer areas B0-B4 at the input nodes of the, lifting structure. The second view of the lifting structure, represented by reference number 1100(2), shows the structure after the final computations are made. Notice that the weights “2a” and “2c” are used to provide a symmetric extension that accounts, for the right boundary of the last frame. These weights simulate an ongoing lifting process, as if the lifting structure was infinite.

[0075] Inverse 3-D Wavelet Transformation (Block 608)

[0076] The video decoder 352 at the client 306 decodes the video using a wavelet synthesis. The synthesis also uses a lifting structure that is similar to the structure used in decomposition, except that the lifting coefficient and phase are different. In one implementation, a pull model in wavelet synthesis is used. With a pull model, a request is sent whenever a wavelet frame is needed and the synthesis algorithm decides which frames should be loaded into the buffers. The reason for this is that the requests are in natural order while the inputs are not.

[0077] Similar to decomposition, the synthesis process consists of three phases: (1) initialization, (2) pipeline processing, and (3) flushing. These three phases are described separately below.

[0078] Initialization (Block 608(1))

[0079] When the first request is received, initialization is exploited and the first five samples are loaded into the lifting structure. FIG. 12 shows two views of a lifting structure during the initialization operation for a one-level wavelet synthesis implemented at the client. The first view of the lifting structure, represented by reference number 1200(1), shows the structure at the point when a request is made and the first five samples are loaded into buffer areas B0-B4 at input nodes 1202. In view 1200(1), data is present at the input nodes 1202, but no operations have yet been performed.

[0080] Negative weighting factors −a, −b, −c and −d are applied to the various paths. Notice that the weighting factors “−2b” and “−2d” are a symmetric extension to account for the left boundary of the first sample.

[0081] The second view of the lifting structure, represented by reference number 1200(2), shows completion of the initialization phase after the operations have been performed. The intermediate and output nodes 704 and 706 now hold coefficients that result from processing, as represented by their solid black appearance. Many of the paths are also filled to demonstrate that the operations have been performed.

[0082] At completion of the initialization operation, the contents of buffer B0 form a coefficient that is ready to be returned. The contents of buffer areas B1-B4 are at various stages of computation.

[0083] Pipeline Processing (Block 608(2))

[0084] After initialization, once a request is received, one sample is loaded and one coefficient is returned. This releases the buffer area previously used to hold coefficient (e.g., buffer area B0). The buffers are updated by shifting their contents to the next buffer area in the structure, as follows:

B0 is output,

B0←B1,

B1←B2,

B2←B3,

B3←B4,

B4←a new sample.

[0085] Notice that a new coefficient now resides in buffer area B0 and a new sample is pushed into the buffer area B4.

[0086] Due to the architecture of the lifting structure, odd and even coefficients are computed differently through the various paths. If the coefficient is odd-numbered, the following operations are performed:

B3←B3+(−d)*B4,

B2←B2+(−c)*B3,

B1←B1+(−b)*B2,

B0←B0+(−a)*B1,

Return B0.

[0087]FIG. 13 shows a version of the lifting structure 1300 upon output of an odd coefficient from buffer area B0 (node 1302) and input of a next sample to buffer area B4 (node 1304).

[0088] Conversely, if the coefficient is even-numbered, the following elementary operations are performed:

B4←B4+(−d)*B3,

B3←B3+(−c)*B2,

B2←B2+(−b)*B1,

B1←B1+(−a)*B0,

Return B0.

[0089]FIG. 14 shows a version of the lifting structure 1400 upon output of an even coefficient from buffer area B0 (node 1402) and input of a next sample to buffer area B4 (node 1404).

[0090] Flushing Stage (Block 608(3))

[0091] When all the samples are loaded and a new request is received, a flushing phase is performed. During this phase, no sample is loaded and the last four requests are satisfied with the remaining buffer contents.

[0092] Multi-Level Decomposition and Synthesis

[0093] The encoding/decoding processes described above concern a one-level decomposition and synthesis. However, the wavelet transform may implement multi-level wavelet decomposition and synthesis.

[0094] For an N-level decomposition, a “push” model is employed. With a push model, input frames in one level are pushed into the buffer for that level and calculations along the lifting structure are performed. Once an output is ready, the output frame is pushed into the buffer for the next level until reaching the final output buffer.

[0095] According to one implementation, each decomposition level has its own independent buffer and the decomposition levels are processed sequentially. Each buffer is sized to hold a specified number of frames (e.g., five frames). For multi-level decomposition, the output of one level is used as the input to the next level. For example, in a two-level Mallat (dyadic) decomposition, the high pass frames of level one are output directly and the low pass ones are pushed into the level two buffer. Using the lifting structure 500 of FIG. 5, each buffer holds five frames for each level. Accordingly, an N-level Mallat wavelet decomposition uses 5N buffers. For other decomposition structures, such as Spa1 and Packet, more than 5N buffers may be warranted. The buffer sizes for various decomposition structures (in terms of frames) are listed in Table 1. TABLE 1 Level Mallat Spacl Packet 1 5 − − 2 10 15 − 3 15 20 35 4 20 25 40

[0096] Rather than independent buffers, another implementation is to use a shared buffer. That is, all the buffers are allocated at the beginning of the transforms and all decomposition levels share a common buffer. To avoid inter-level interference, more space is allocated.

[0097]FIG. 15 shows a two-level Mallat decomposition structure 1500, in which buffer areas B1 to B12 are not changed until the node “i” is ready for output. Once buffer area B0 is ready, buffer areas B0 to B3 can be output one by one and the memory will be available for reuse. With this approach, suppose Buf(i) is the minimal buffer requirements (in terms of frames) needed to implement an i-level decomposition, which is given by the following recursive formula:

Buf(i+1)=Buf(i)+2^(i+2) , iεZ ⁺, with Buf(0)=1.

[0098] The buffer requirements for the Spad1, Packet or other decomposition structures are the same because they are determined only by the decomposition level and by the filter lengths used. Table 2 summarizes buffer requirements (in terms of numbers of frames). TABLE 1 Level Mallat Spacl Packet 1 5 − − 2 13 13 − 3 29 29 29 4 61 61 61

[0099] From Tables 1 and 2, the independent−buffer approach is more memory efficient in most cases. However, the output order is irregular in this approach because a wavelet frame is immediately output once it is ready. That is: low-level high pass frames are always output in advance of its original order compared with other wavelet frames due to the process delay. This makes it improper for some coding algorithms with order requirements. Extra buffers are used to facilitate wavelet frame ordering.

[0100] In the shared-buffer approach, however, the extra buffers can also be used for frame rearrangement, thus they can guarantee the required order. In addition, the shared-buffer method is more suitable for other decomposition structures. In fact, the buffer requirements are the same for different decompositions, as indicated by Table 2.

[0101] Finally, both approaches give the same delay in the wavelet transform. For example, the delay is four frames for one-level decomposition since one output frame is related to four frames. The delay is 12 frames for two-level decomposition because one output frame is related to 12 frames.

[0102] Depending on the buffering method used in the wavelet analysis, there are two ways for implementing an N-level wavelet synthesis: independent−buffer method and shared−buffer method. The buffer requirement and delay are the same as in the analysis case.

[0103] Experimental Results

[0104] A test was performed using the memory−constrained wavelet transform described above. The transform was applied to a 288-frame QCIF “Akiyo” test sequence with a three-level Mallat temporal decomposition followed by a three-level spatial decomposition for each frame. The shared-memory approach was used with a 29-frame memory (See Table 2). The wavelet frames were exactly the same as those obtained by using the conventional transform that buffers the whole sequence (all 288 frames).

[0105] To compare our proposed transform scheme with the conventional transform scheme in real coding scenarios, two coding experiments were conducted: uniform quantization and coding and 3-D SPIHT coding. When the proposed transform scheme is used, the transformed frames are divided into GOPs. Note that doing so will not introduce any boundary effect. When the conventional transform scheme is used, however, the frames are divided into 11 GOPs before wavelet transform due to memory constraint. The transform structure is the same in both cases (three-level temporal followed by three-level spatial). After lossy coding (uniform quantization and coding or 3-D SPIHT coding), inverse transform is used to decode the sequence.

[0106]FIG. 16 shows PSNR curves from the two transform schemes using uniform quantization (stepsize=64) and coding. FIG. 17 shows the PSNR curves from the scheme using 3-D SPIHT coding at 20 kbps. Uniform bit rate allocation is used for different GOPs in 3-D SPIHT. From these figures, one can appreciate that the transformation scheme described herein solves the PSNR dipping problem at GOP boundaries. The overall average PSNR is about 0.2 dB higher than that corresponding to the conventional scheme. In video playback, the proposed transform scheme gives much smoother and better visual quality because the boundary effects are completely eliminated.

[0107] Conclusion

[0108] Although the description above uses language that is specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the invention. 

1. A method comprising: inputting consecutive frames from a video sequence into a buffer; processing the frames according to a lifting structure to produce associated wavelet coefficients; and outputting consecutive wavelet coefficients from the buffer such that as one wavelet coefficient is output, buffer space is freed to receive a next frame input.
 2. A method as recited in claim 1, wherein the inputting, the processing, and the outputting are performed continuously.
 3. A method as recited in claim 1, wherein the processing comprises performing a one-level wavelet decomposition on the frames.
 4. A method as recited in claim 1, wherein the processing comprises performing a multi-level wavelet decomposition on the frames.
 5. A method as recited in claim 1, wherein the processing comprises processing the frames using an x9-7 filter.
 6. A method as recited in claim 1, further comprising buffering partially computed wavelet coefficients in the buffer until the next frame is input to simulate an infinite wavelet transformation across frame boundaries.
 7. A computer-readable medium comprising computer-executable instructions that, when executed by a processor, perform the method as recited in claim
 1. 8. A method comprising: segmenting a buffer into a specified number of areas to hold coefficients computed at different lifting steps of a lifting function; and continuously processing consecutive groups of pictures (GOPs) from a video sequence by buffering coefficients at intermediate lifting steps towards an end of one GOP until intermediate coefficients from a beginning of a next GOP are available.
 9. A method as recited in claim 8, further comprising initializing the buffer with an initial set of frames from the video sequence.
 10. A method as recited in claim 8, wherein the processing comprises: initializing the buffer with an initial set of frames from the video sequence; processing the frames continuously by adding new frames to the buffer as processed coefficients are output from the buffer; and flushing a last set of frames from the buffer.
 11. A method as recited in claim 8, wherein the processing comprises updating the buffer areas by shifting contents from one buffer area to another buffer area.
 12. A method as recited in claim 8, wherein the buffer is segmented into N areas B0, B, . . . BN, and the processing comprises outputting contents of buffer area B0 and updating the buffer areas as follows: B0←B1, B1←B2, BN−1←BN, BN←new picture.
 13. A method as recited in claim 8, wherein the buffer is segmented into five areas B0, B1, B2, B3, and B4, and the processing comprises performing the following operations for an odd-numbered picture from the video sequence: B4←B4+a*B3, B3←B3+b*B2, B2←B2+c*B1, B1←B1+d*B0, Output B0. where a, b, c, and d are weights dictated by the lifting function.
 14. A method as recited in claim 8, wherein the buffer is segmented into five areas B0, B1, B2, B3, and B4, and the processing comprises performing the following operations for an even-numbered picture from the video sequence: B3←B3+a*B4, B2←B2+b*B3, B1←B1+c*B2, B0←B0+d*B1, Output B0. where a, b, c, and d are weights dictated by the lifting function.
 15. A computer-readable medium comprising computer-executable instructions that, when executed by a processor, perform the method as recited in claim
 8. 16. A method comprising: inputting consecutive frames from a video sequence into a buffer; and continuously processing the frames according to a lifting structure by outputting fully-processed coefficients from the buffer and buffering partially-processed coefficients at intermediate lifting steps until a next frame is input.
 17. A method as recited in claim 16, further comprising defining multiple areas in the buffer such that different buffer areas hold a set of frames at various stages of processing.
 18. A method as recited in claim 16, wherein the processing comprises processing the frames using an x9-7 filter.
 19. A computer-readable medium comprising computer-executable instructions that, when executed by a processor, perform the method as recited in claim
 16. 20. A method comprising: inputting consecutive samples into a buffer; and continuously processing the samples according to a lifting structure by outputting fully-processed coefficients from the buffer and buffering partially-processed coefficients at intermediate lifting steps until a next sample is input.
 21. A method as recited in claim 20, further comprising initializing the buffer with an initial set of samples.
 22. A method as recited in claim 20, wherein the processing comprises: initializing the buffer with an initial set of samples; processing the samples continuously by adding new samples to the buffer as processed coefficients are output from the buffer; and flushing a last set of samples from the buffer.
 23. A method as recited in claim 20, wherein the buffer is segmented into N areas B0, B1, . . . BN, and the processing comprises outputting contents of buffer area B0 and updating the buffer areas as follows: B0←B1, B1←B2, BN−1←BN, BN←new picture.
 24. A method as recited in claim 20, wherein the buffer is segmented into five areas B0, B1, B2, B3, and B4, and the processing comprises performing the following operations for an odd-numbered coefficient: B3←B3+(−d)*B4, B2←B2+(−c)*B3, B1←B1+(−b)*B2, B0←B0+(−a)*B1, Return B0. where a, b, c, and d are weights dictated by the lifting structure.
 25. A method as recited in claim 20, wherein the buffer is segmented into five areas B0, B1, B2, B3, and B4, and the processing comprises performing the following operations for an even-numbered coefficient: B4←B4+(−d)*B3, B3←B3+(−c)*B2, B2←B2+(−b)*B1, B1←B1+(−a)*B0, Return B0. where a, b, c, and d are weights dictated by the lifting structure.
 26. A computer-readable medium comprising computer-executable instructions that, when executed by a processor, perform the method as recited in claim
 20. 27. A video encoder comprising: a buffer to store individual frames of a video sequence and coefficients computed from the frames; and a wavelet transformer to transform the frames in the video sequence into wavelet coefficients such that partially-processed wavelet coefficients are held in the buffer as additional frames are input to the buffer to simulate an infinite wavelet transformation across frame boundaries.
 28. A video encoder as recited in claim 27, wherein as fully-processed wavelet coefficients are output from the buffer, memory space in the buffer is freed to receive a next frame in the video sequence.
 29. A video encoder as recited in claim 27, wherein the wavelet transformer uses a 9-7 biorthogonal filter.
 30. A video encoder as recited in claim 27, wherein the buffer is segmented into multiple areas such that different buffer areas holds a set of frames at various stages of transformation.
 31. A video encoder as recited in claim 27, wherein the wavelet transformer performs a one-level temporal decomposition to transform the frames.
 32. A video encoder as recited in claim 27, wherein the wavelet transformer performs a multi-level decomposition to transform the frames.
 33. A video decoder comprising: a buffer to store individual samples; and an inverse wavelet transformer to synthesize wavelet coefficients from the samples, wherein partially-processed wavelet coefficients are held in the buffer as additional samples are input to the buffer.
 34. A video decoder as recited in claim 33, wherein as fully-processed wavelet coefficients, are output from the buffer, memory space in the buffer is freed to receive a next sample.
 35. A video decoder as recited in claim 33, wherein the buffer is segmented into multiple areas such that different buffer areas holds a set of frames at various stages of transformation.
 36. A video decoder as recited in claim 33, wherein the inverse wavelet transformer employs a pull model for wavelet synthesis.
 37. A video encoder comprising: means for buffering consecutive frames from a video sequence; means for processing the frames according to a wavelet transform to produce wavelet coefficients; and means for outputting fully computed wavelet coefficients and for buffering partially-processed wavelet coefficients until a next frame is buffered to simulate an infinite wavelet transformation across frame boundaries.
 38. A video encoder as recited in claim 37, wherein the processing means utilizes a lifting structure.
 39. A video encoder as recited in claim 37, wherein the processing means comprises an x9-7 filter.
 40. A computer-readable medium comprising computer-executable instructions that, when executed on a processor, direct a device to: perform n-level wavelet decomposition of a frame in a video sequence using a lifting structure with multiple lifting steps, where n 1; and buffer partially-processed wavelet coefficients at intermediate lifting steps.
 41. A computer-readable medium as recited in claim 40, further comprising computer-executable instructions that, when executed on a processor, direct a device to perform the wavelet decomposition using a 9-7 biorthogonal filter.
 42. A computer-readable medium as recited in claim 40, further comprising computer-executable instructions that, when executed on a processor, direct a device to perform n-level temporal decomposition.
 43. A computer-readable medium as recited in claim 40, further comprising computer-executable instructions that, when executed on a processor, direct a device to output fully-processed wavelet coefficients to free buffer space for a next frame in the video sequence. 